SOS with variables

In the previous code we have a SOS with simple instructions. We're going to convert simple instructions into instructions with variables. Variables are declared at the beggining of the code. Remember that are many types of variables (Int, byte, float, bool, double, char...), those variables can be signed or unsigned, global variables are used all along the code, and local variables are used only inside a function and do not exsist outside that specific function. In this case the global variable is "t" = 200 ;, sometimes a variable can be constant in all the code so I can declare const int t = 200 ;. When I declare a variable the computer keep a space in the memory for that variable and keep that name.

What is the advantage of creating a variable? You don't need to repeat a value all the time, it is more effective because I write once and the value is changed every time

Time variable is some times t and sometimes 3*t or 7*t because the rules of the Morse code :

Another posibility is to create 3 variables, one is dot, another is dash and the last is space, the code will be : const int dot = 200 ; const int dash = 3*dot ; const int space = 7*dot ;

The structure of the code is always the same :

  1. Comment about the objective and author of the code
  2. Importing libraries needed for my code, for example if I'm using computer vision I need to import the computer vision library in order to use the computer vision instructions
  3. SetUp function contains the settings of my code : output of input, screen size...
  4. My own functions created by myself , in this case to be used in the main code
  5. The main code is the loop function and in this case contains only simple instructions with variables and do not call any function created by myself
  6. 
    
    
    /*
      Blink
    
    
      Turns an LED on for one second, then off for one second, repeatedly.
    
      Most Arduinos have an on-board LED you can control. On the UNO, MEGA and ZERO
      it is attached to digital pin 13, on MKR1000 on pin 6. LED_BUILTIN is set to
      the correct LED pin independent of which board is used.
      If you want to know what pin the on-board LED is connected to on your Arduino
      model, check the Technical Specs of your board at:
      https://www.arduino.cc/en/Main/Products
    
      modified 8 May 2014
      by Scott Fitzgerald
      modified 2 Sep 2016
      by Arturo Guadalupi
      modified 8 Sep 2016
      by Colby Newman
    
      This example code is in the public domain.
    
      https://www.arduino.cc/en/Tutorial/BuiltInExamples/Blink
    */
    const int t = 200 ; global variable 
    
    // the setup function runs once when you press reset or power the board
    void setup() {
      // initialize digital pin LED_BUILTIN as an output.
      pinMode(LED_BUILTIN, OUTPUT);
    }
    
    // the loop function runs over and over again forever
    void loop() {
      digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t);   
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);    
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t);    
         digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);
          digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);
          digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t);
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);   
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);   
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(3*t); 
          digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);   
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);   
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);   
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(3*t);  
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t); 
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);   
        digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t);    
        digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);    
         digitalWrite(LED_BUILTIN, HIGH);   // turn the LED on (HIGH is the voltage level)
      delay(t);
          digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(t);
          digitalWrite(LED_BUILTIN, LOW);   // turn the LED on (HIGH is the voltage level)
      delay(7*t);
    
    
    }